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Worksheet 2 Searching algorithms 
Task 1 


Use the 10 name cards for the activities in Task 1. 


1. With the 10 name cards in a sequenced row, face down, use the binary search 
algorithm to search for the name Emily 


Leave the cards you have examined face up. 
Which card did you turn up first? 
Which card did you turn up second? 
Which card did you turn up third? 
2. Turn the cards face down again. 
Now search for the name Sophie 


Which cards did you turn up? Write them in order. 


What is the maximum number of cards you will need to find any given name? 


What is the maximum number of items you will have to examine if the list 
contains 


¢ 8 items? 

e 16 items? 
e 32 items? 
e 37 items? 
e 64 items? 
e 2° items? 


3. What is the time complexity of the binary search algorithm? Explain your 
answer. 
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4. Anincomplete algorithm for the binary search is given below. 
Complete the missing statements 1-5. 


function binarySearch(aList, itemSought) 
found = False 


index = -1 

first = 0 

last = len(aList)-1 

while first <= last and found == (1) 


midpoint = (first + last) div 2 
if aList[midpoint] == itemSought then 
found = (2) 


else 
if aList[midpoint] < itemSought then 
first = (4) 
else 


endif 
endif 
endwhile 
return index 
endfunction 
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Task 2 


5. (a) Complete the table corresponding to the following binary search tree, 
assuming that the data was entered in the order: K, E, H, R, U, N, T, B, C, Z: 


Left Data Right 


0 
1 
2 
3 
4 
5 
6 
7 
8 
9 


(b) Which items are visited when searching for: 


(ii) N? 


